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Percona MySQL 


М.ВидеоЭльдорадо 


e 1000+ SOL запросов на странице без кеша 
e 40-50k общий rps Ha кластер БД 
e Чтение с мастеров! 


2 AKTMBHbIX мастера? 
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slave-db2-1 


slave-db2-2 


М.ВидеоЭльдорадо 


- НіРћ оаа 
(ні) йен 


ВНИМАНИЕ 


Все трюки выполнены 
профессионалами, ради 
собственной безопасности и 
безопасности окружающих не 
пытайтесь их повторить 


Больше мастеров - больше стабильности? 


slave-db1-1 slave-db4-1 
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М.ВидеоЭльдорадо 


Г\ HighLoad 
(н) нен ова 


NU 
Больше мастеров - больше стабильности? NS 


° A ecan отказал любой из 4 таѕіег ов? 
° Å ecan прилетел тяжелый апдейт? 
° Сколько шагов репликации должен пройти апдейт с таѕіег01 до слейва 4-12 


slave-db1-1 slave-db4-1 


slave-db4-2 


slave-db1-2 


М.ВидеоЭльдорадо 


slave-db2-1 slave-db3-1 


A HighLoad 
(HL) ые ú 


e 150 000 товаров * 100 регионов * цены 

e 150 000 товаров * 100 регионов * остатки 
e Логистические цепочки 

° v5.5 на мастерах =» binlog row image FULL 


[/var/lib/mysql/mysql-bin-master02.001832] 2021-05-13 00:11:00 -- 2021-05-13 00:12:00 
[/var/lib/mysql/mysq]-bin-master02.001833] 2021-05-13 00:11:00 -- 2021-05-13 00:12:00 
15161 ### UPDATE 'eldorado2'."b iblock element prop 531 
12000 ### DELETE FROM 'eldorado2'. тм sap. group2type transport' 
10371 ### UPDATE 'eldorado2'.'b catalog product' 
3128 ### INSERT INTO 'eldorado2'.'b sale fuser' 
1451 ### UPDATE "eldorado2'. b catalog price' 
00:12:00 2021-05-13 -- 00:13:00 2021-05-13 
[/var/lib/mysql/mysql-bin-master02.001832] 2021-05-13 00:12:00 -- 2021-05-13 00:13:00 
[/var/lib/mysql/mysq]-bin-master02.001833] 2021-05-13 00:12:00 -- 2021-05-13 00:13:00 
36218 ### UPDATE 'eldorado2'.'b iblock element prop 531 
7000 444 DELETE FROM 'eldorado2'. тм sap group2type transport' 
4877 ### UPDATE еідогадо?'.Ь catalog product' 
2093 HH INSERT INTO 'eldorado2'.'b sale fuser' 
175 ### UPDATE 'eldorado2'.'b catalog price" 
00:13:00 2021-05-13 -- 00:14:00 2021-05-13 
[/var/lib/mysql/mysq]-bin-master02.001832] 2021-05-13 00:13:00 -- 2021-05-13 00:14:00 
[/var/lib/mysql/mysql-bin-master02.001833] 2021-05-13 00:13:00 -- 2021-05-13 00:14:00 
50002 ### DELETE FROM 'eldorado2'.'b sale fuser' 
44609 ### UPDATE 'eldorado2'.'b iblock element prop s31' 
12000 ### DELETE FROM 'eldorado2'. mv sap group2type transport' 
11891 ### UPDATE 'eldorado2'."b catalog product' 
1667 ### UPDATE "eldorado2'.b catalog ргісе! 
00:14:00 2021-05-13 -- 00:15:00 2021-05-13 
[/var/lib/mysql/mysq]-bin-master02.001832] 2021-05-13 00:14:00 -- 2021-05-13 00:15:00 
[/var/lib/mysql/mysq]-bin-master02.001833] 2021-05-13 00:14:00 -- 2021-05-13 00:15:00 
45257 ### DELETE FROM 'eldorado2'.'b sale fuser' 
18862 HHH UPDATE 'eldorado2'."”b iblock element prop s31' 
12665 ### UPDATE 'eldorado2'."b catalog product' 
12000 ### DELETE FROM 'eldorado2'. mv. sap. group2type transport' 
1712 ### UPDATE 'eldorado2'.'b catalog ргісе! 


NS 
ЧТО AEAATb? NS 


Синхронная репликация в БД медленная. 
Асинхронная остается преобладающей для масштабирования скорости и доступности. 


ВАРИАНТЫ ( ) 


NDB GALERA Percona 
CLUSTER CLUSTER XtraDB CLUSTER 
Совсем не в TY степь хорошо, HO нет галера под капотом? 
гарантии на blackhole Нет гарантии на 
blackhole 


М.ВидеоЭльдорадо 


RW 
HE ПОВТОРЯТЬ 


Master: ALTER TABLE superbigtable ENGINE=BBLACKHOLE; 


Slave: ALTER TABLE superbigtable ENGINEZINNODB; 


Ограничения SN 


„_ ленивые GAAA4HHbI 
° Использование фишек репликации (blackhole обязательно) 
° Максимальная совместимость с текущим кодом Ŝi инструментами обслуживания 


e Без даунтайма! 


М.ВидеоЭльдорадо 


A HighLoad++ 
(HL) Вы 


MySQL 5.5 


5.5 на мастерах, 5.7 на слейвах 
Официальная документация: 


«when upgrading to MySQL 5.7, the slaves must be MySQL 5.7 before you can upgrade the 
master їо 5.7.) 
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A HighLoad++ 
(HL) o 


Обновление с 5.5 AO 5.7 


ріпіод checksum=NONE 
binlog. row image=FULL 

binlog. rows query. log events=OFF 
log. bin use VI row events=] 


М.ВидеоЭльдорадо 


c 5.5 Ha 5.7 B KOMbLLE 


| 


mysql -h127.0.0.1 -P 3302 -e "ВЕЗЕТ SLAVE; RESET MASTER; SHOW MASTER STATUSNG;" 


mysql -h127.0.0.1 -P 3302 -e "CHANGE MASTER TO MASTER. HOST='127.0.0.1', MASTER PORT=3301, MASTER USER='root', MASTER PASSWORD=", MASTER LOG. FILE='master1-binlog.OO0001', MASTER LOG. POS = ОДТАКТ АМЕ” 


mysql -h127.0.0.1 -P 3303 -e "ВЕЗЕТ SLAVE; RESET MASTER; SHOW MASTER STATUSNG;" 


mysql -h127.0.0.1 -P 3303 -e "CHANGE MASTER TO MASTER. HOST='127.0.0.1', MASTER PORT=3302, MASTER USER='root', MASTER PASSWORD=", MASTER LOG. FILE='master2-binlog.OO0001', MASTER LOG. POS = ОДТАКТ АМЕ” 


mysql -h127.0.0.1 -P 3304 -e "ВЕЗЕТ SLAVE; RESET MASTER; SHOW MASTER STATUSNG;" 


mysql -h127.0.0.1 -P 3304 -e "CHANGE MASTER TO MASTER, HOST='127.0.0.1', MASTER PORT=3303, MASTER USER='root', MASTER PASSWORD=", MASTER LOG, FILE='master3-binlog.O00001', MASTER LOG. POS = ОДТАКТ АМЕ” 


mysql -h127.0.0.1 -P 3301 -e "ВЕЗЕТ SLAVE; RESET MASTER; SHOW MASTER STATUSNG;" 


mysql -h127.0.0.1 -P 3301 -e "CHANGE MASTER TO MASTER, HOST='127.0.0.1', MASTER PORT=3304, MASTER USER='root', MASTER PASSWORD=", MASTER LOG, FILE='master4-binlog.OO0OO1', MASTER LOG. POS = ОДТАКТ АМЕ” 


М.ВидеоЭльдорадо 
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MultiSource? 


12 


М.ВидеоЭльдорадо 


- HighLoad+ 
(н) кее 


LRANS 
MultiSource SS 


master2 master3 


master 


master1 master4 


М.ВидеоЭльдорадо 


CHANGE MASTER TO master log. file=mysqg]l-bin.OOO1', master log. pos=O FOR CHANNEL “master1”; 
SHOW SLAVE STATUS FOR CHANNEL “master2”; 


- HighLoad 
(н) Highl oach 


2. 


Новая схема 


- HighLoad+ 
(HL) нето 
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План миграции 


slave-db4-1 


slave-db1-1 


slave-db1-2 slave-db4-2 
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Multimaster0O1 + 
log slave updates=1 ——— multimasterO2 
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multimaster03 multimaster04 
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Online миграции 


httos://github.com/github/gh-ost 


original = ghost 
table table 
À 


М.ВидеоЭльдорадо 


LA HighLoad 
(н) нен ова 


e Сложнее настраивать, 
поддерживать, 
мониторить 

e Разная скорость RI 
проигрывания бинлогов 

e Неконсистентность 


М.ВидеоЭльдорадо 


slave parallel workers=5 
slave parallel type=LOGICAL CLOCK 


A HighLoad+ 
(н) нен ова 


Плюсы 


оподорчиєовітия уу 


со 
„ 29 
Š бо se 
= I J O Ln 

< Ф N 
- = Ф 

LO = 
Ф C о © 
оо © I 
vag G = O = 
xv = O m x O 
X Fm >x >x О б 
ó & °$ ë o 5 ÉE р 
20508008 с 
Ф v к оса 
со з O Е 

7 G = = о © 

о о 2 чо = 
= O Z o O Ë š EI 
Q Oo “£ с O G Ë © 
=a2om == а E 
e ө ө ө 


v 


AN». 
\ K \ Р : 


A HighLoad 
сн miĝi 


Факап года 


ради собственной 
безопасности и 
безопасности окружающих 
не пытаитесь повторить 
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М.ВидеоЭльдорадо 


Вопросы? 


